#### Digital Logic Design: Sequential Circuit



# Z. Jerry Shi Department of Computer Science and Engineering University of Connecticut

Based on materials from Computer Organization: the Hardware/Software Interface by D. Patterson and J. Hennessy

#### Appendix A

in history of Input )

- Clock
- Memory elements

Memory elements

- D Flip-flops, registers, register file

LIGHT

State machines and timing

TD44

|            | 7   | MHZ    |          | Truits |           |      |
|------------|-----|--------|----------|--------|-----------|------|
| G          | M   | K      | unit     | m      | u         | n    |
| $(10^{9})$ | 106 | $10^3$ | $10^{0}$ | 10-3   | $10^{-6}$ | 10-9 |
|            |     |        |          |        |           |      |

Reading: Sections A.7 - A.11

#### Combinational versus sequential

#### Two types of circuit:

- Combinational circuit: the outputs depend on the current input values
- Sequential circuit: the outputs also depend on the history of inputs
  - Two identical sequential circuits may produce different outputs even if their current inputs are the same

#### Clock



- A clock signal oscillates between high and low values
- The clock period is the time for one full cycle : 𝔻 < /
  - Also called clock cycle time ( )
  - The clock rate is the reciprocal of the cycle time = frequence ( (+z)

If the clock cycle time is 1 ns, the clock rate is 1 GHz. If the clock rate is 2 GHz, the clock cycle time is 0.5ns.

1 = 0.5 ns



#### Question

If a processor runs at 200 MHz, what is the clock cycle time in ns?

Round to the nearest integer.

Why cannot the processor run at higher clock rates?
We are going to see why.

#### Bistable element

- A bistable element has two states: Q is 0 or 1
- The simplest sequential circuit to remember something
  - Need memory to remember history in sequential circuit



Based on bistable element, we build flip-flops, which are easier to use

#### D flip-flop, positive edge triggered

- D flip-flop stores input D at the trigger, the rising edge of C
  - We can control what and when
  - To store a bit in D flip-flop: set up D, and then make C transit from 0 to 1
  - The saved bit does not change until another value is stored



#### Timing requirements of D Flip-Flop

Setup time: D has to be steady for some time before the edge

Hold time: D has to be steady for some time after the edge

Propagation delay: Time for input to propagate to output



## Register $(\chi_0 - \chi_{31})$

- Register: a memory element that stores data
  - Can be a D flip-flop, or other kind of flip-flops
- A clock signal determines when to update the data
  - The timing diagram below is for a positive edge-triggered register
  - Update happens when clock changes from 0 to 1
- Data stored in registers are steady until next trigger



#### Register with write control

RISC-V { write (Rd) Yead (RS1, RS2)

- The register is updated with D on clock edge only when write control input is 1
  - Otherwise, keep the original value in the register
  - Often, the Write signal is also called Enable



How would you add the Write control?



#### **Multibit Register**

- But that's only 1 bit
- How would you build a 32-bit register?



#### 32-bit Register

- An array of 1-bit registers
  - Controlled by the same clock



Remember RISC-V has 32 registers?



#### Register File

- The register file has 32 32-bit Registers
- How do we select the register we need?



#### **Inside the RF: Read ports**

RSI RS2 -> add XI, X30 XBI

 Two MUXes for Two read ports



How do we select the register to write?

14

Inside the RF: Write port Write Write goes to AND gates Write Register 0 n-to-2n Register number decoder Write Register number goes into a Register 1 n-2decoder, which activates only one register n-1Write Register n-2 Data to be stoved Register Data are Write Register n-1/ sent to all registers Register data Clock

15

#### Register File

- Register File (RF) has a collection of registers
- RISC-V RF has 32 32-bit registers
  - Two read ports: can read two registers at the same time

addi?

- One write port
  - Set Write to 0 if the instruction does not write to a register

beg X

#### Read

Set read register numbers Wait for data to be ready

#### Write

Set write register and write data Set Write to 1 Wait for clock to change

Clock? Not shown.



#### **State Machine**

- The circuit has multiple states
  - A state is a summary of previous inputs
- The circuit does two things, depending on current state and input
  - Generate output,
  - Decide the new state to transit to



#### **Components in a State Machine**

- A state machine consists of
  - Memory elements that keep the state
    - Commonly use edge-triggered memory elements
    - All bits are updated at the clock edges and kept steady during the cycle
  - Two combinational functions
    - One generates output
    - One generates the next-state, which will be saved in memory elements when triggered



#### Example: a 16-bit Accumulator

- Add an input number to the existing value in the register
  - If In is 1, the accumulator works as a counter



Identify the following:

#### What is happening in a cycle

- Between clock edges:
  - New state is stored in the state elements
  - Combinational logic computes
  - State for next cycle is presented at the input of the state elements
- The clock cycle must be long enough to complete all work



#### Example of a 16-bit Accumulator

• What happens in a cycle (when accumulating)?



#### **Clock Rate**

The clock cycle must be longer than the sum of the following delays

t<sub>prop</sub>: The time for a flip-flop to propagate input to the output;

t<sub>combinational</sub>: The time for the combinational logic to work;

t<sub>setup</sub>: New state must arrive early enough to meet the setup requirement



Identify the delays on the previous slides. Where is the hold time?

#### Question

The setup time and hold time of the register is 2ns and 1ns, respectively The propagation delay of the register is 3 ns.

The propagation delay of the adder is 10 ns.

What is the fastest clock rate in MHz the accumulator can work at? Truncate to the nearest integer.



#### **Solutions**

The clock cycle must be longer than the sum of the following delays

t<sub>prop</sub>: The time for a flip-flop to propagate input to the output;

t<sub>combinational</sub>: The time for the combinational logic to work;

t<sub>setup</sub>: New state must arrive early enough to meet the setup requirement

Clock cycle time 
$$\Rightarrow$$
  $t_{prop} + t_{combinational} + t_{setup} = 3+10+2 = 15$ ns  
Clock rate  $\Rightarrow$  1 / 15ns = 0.0667 GHz = 66 MHz

#### **Design of memory**

- Memory provides a <u>large storage</u> for processors
- Conceptually, memory is just a large register file, but it is very large, which changes many design decisions
  - Each cell (for a bit) must be small and cheap
    - Not using flip-flops
  - Memory is slow (very slow)
    - Pick one word out of 32 vs one out of 1 billion
    - Memory has its own clock
  - Memory consumes a lot of energy

# Memory VS. RF Read - Set Address and MemRead (to 1), and wait - Get the data from Read data Store RF Load (read MEM Store (write) Load Store Store

#### Write

- Set Address, Write data, and MemWrite (to 1), and wait



MemWrite and MemRead should not be 1 at the same time

#### **Example: Shift Register**

- Registers that can shift bits to right (or left)
  - A simple state machine

For example: 4-bit shift register (shift right)



|                 | Cycle | S  | В3  | B2 | <b>B</b> 1 | В0           |
|-----------------|-------|----|-----|----|------------|--------------|
| <b>→</b>        | 0     | 0_ | 1 _ | 0  | 1_         | 1            |
| $ \rightarrow $ | 1     | 1  | √ 0 |    | >>0        | $\searrow$ 1 |
| ->              | 2     | 1  | 1   | 0  | 1          | 0            |
|                 | • • • |    |     |    |            |              |

#### Example: 4-bit shift register

#### Shift right

Bits to be stored in the register in the next cycle: (S, B3, B2, B1)

- S is connected to D3 because we want S to be stored in bit 3 of the register
- Similarly, B3 is connected to D2, B2 to D1, and B1 to D0



How about shift left?

### Clock skew XX (not in exam)

- Clock arrives at memory elements at different times
  - Also called timing skew
- Clock cycle time needs to include the clock skew
  - However, we don't consider it in this course



## D flip-flop, negative edge triggered

Negative edge triggered D flip-flop stores D at the falling edge



#### Register with reset and enable in HDL

```
In Verilog:
always @ (posedge clk or posedge reset)
begin
    if (reset == 1) begin
        q <= 0;
    end else if (enable == 1) begin
        q <= d;
    end
end
In MyHDL:
@always_seq(clk.posedge, reset=reset)
def seq_reg():
    if enable:
        q.next = d
```

#### Truth table in state machine

Assume 3-bit state, 2-bit input, 2-bit output For each state and input combination, specify what the next state and output are

|         |  |       |    |    |    |    | Next state |           |    | Output |      |
|---------|--|-------|----|----|----|----|------------|-----------|----|--------|------|
|         |  | S2    | S1 | SØ | I1 | 10 | <b>S2</b>  | <b>S1</b> | SØ | Out1   | Out0 |
| State 0 |  | 0     | 0  | 0  | 0  | 0  |            |           |    |        |      |
|         |  | 0     | 0  | 0  | 0  | 1  |            |           |    |        |      |
|         |  | 0     | 0  | 0  | 1  | 0  |            |           |    |        |      |
|         |  | 0     | 0  | 0  | 0  | 1  |            |           |    |        |      |
| State 1 |  | 0     | 0  | 1  | 0  | 0  |            |           |    |        |      |
|         |  | 0     | 0  | 1  | 0  | 1  |            |           |    |        |      |
|         |  | 0     | 0  | 1  | 1  | 0  |            |           |    |        |      |
|         |  | 0     | 0  | 1  | 0  | 1  |            |           |    |        |      |
|         |  | • • • |    |    |    |    |            |           |    |        |      |